

What Is Claimed Is:

1. A delay optimization designing system for a logic circuit including a plurality of flip-flops and a combinational circuit formed from logic circuit elements, 5 comprising:

    flip-flop selection means for selecting any flip-flop not to be substituted into a latch from within a given logic circuit;

10    flip-flop searching means for searching any flip-flop having a delay margin from among the flip-flops which are not selected by said flip-flop selection means; and

15    latch substitution means for substituting any flip-flop searched by said flip-flop searching means into a latch which passes a signal to the output side therethrough faster than the searched flip-flop.

2. A delay optimization designing system for a logic circuit as claimed in claim 1, wherein the flip-flop holds data inputted in response to an edge of a clock upon variation from a first level to a second level, and the latch 20 substituted by said latch substitution means passes input data when the clock indicates the first level therethrough to the output side.

3. A delay optimization designing system for a logic circuit as claimed in claim 1, further comprising latch

insertion means for inserting a second latch, which passes input data at a timing different from that of the latch substituted by said latch substitution means, into a predetermined portion of the logic circuit.

5. 4. A delay optimization designing system for a logic circuit as claimed in claim 3, wherein the second latch inserted by said latch insertion means passes input data when the clock indicates the second level therethrough to the output side.

10. 5. A delay optimization designing system for a logic circuit as claimed in claim 3, wherein the second latch inserted by said latch insertion means is arranged on the output side of the latch substituted by said latch substitution means.

15. 6. A delay optimization designing method for a logic circuit including a plurality of flip-flops and a combinational circuit formed from logic circuit elements, comprising:

20. a flip-flop selection step of selecting any flip-flop not to be substituted into a latch from within a given logic circuit;

a flip-flop searching step of searching any flip-flop having a delay margin from among the flip-flops which are not selected at the flip-flop selection step; and

a latch substitution step of substituting any flip-flop searched at the flip-flop searching step into a latch which passes a signal to the output side therethrough faster than the searched flip-flop.

5. 7. A delay optimization designing method for a logic circuit as claimed in claim 6, wherein the flip-flop holds data inputted in response to an edge of a clock upon variation from a first level to a second level, and the latch substituted at the latch substitution step passes input data  
10 when the clock indicates the first level therethrough to the output side.

8. A delay optimization designing method for a logic circuit as claimed in claim 6, further comprising a latch insertion step of inserting a second latch, which passes input data at a timing different from that of the latch substituted at the latch substitution step, into a predetermined portion of the logic circuit.  
15

9. A delay optimization designing method for a logic circuit as claimed in claim 8, wherein the second latch inserted at the latch insertion step passes input data when the clock indicates the second level therethrough to the output side.  
20

10. A delay optimization designing method for a logic circuit as claimed in claim 8, wherein the second latch

inserted at the latch insertion step is arranged on the output side of the latch substituted at the latch substitution step.

11. A program for causing a computer to perform a delay 5 optimization designing method for a logic circuit including a plurality of flip-flops and a combinational circuit formed from logic circuit elements, comprising:

10 a flip-flop selection step of selecting any flip-flop not to be substituted into a latch from within a given logic circuit;

a flip-flop searching step of searching any flip-flop having a delay margin from among the flip-flops which are not selected at the flip-flop selection step; and

15 a latch substitution step of substituting any flip-flop searched at the flip-flop searching step into a latch which passes a signal to the output side therethrough faster than the searched flip-flop.

12. A program as claimed in claim 11, wherein the flip-flop holds data inputted in response to an edge of a clock upon 20 variation from a first level to a second level, and the latch substituted at the latch substitution step passes input data when the clock indicates the first level therethrough to the output side.

13. A program as claimed in claim 11, further comprising a

latch insertion step of inserting a second latch, which passes input data at a timing different from that of the latch substituted at the latch substitution step, into a predetermined portion of the logic circuit.

5 14. A program as claimed in claim 13, wherein the second latch inserted at the latch insertion step passes input data when the clock indicates the second level therethrough to the output side.

10 15. A program as claimed in claim 13, wherein the second latch inserted at the latch insertion step is arranged on the output side of the latch substituted at the latch substitution step.